home *** CD-ROM | disk | FTP | other *** search
/ Chip 1996 September / CHIP Eylül 1996.iso / utils / povray / povsrc.sea / POVSRC / SOURCE / CONES.C < prev    next >
MacBinary  |  1993-07-28  |  11.1 KB  |  [TEXT/MPS ]

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


This file was processed as: MacBinary (archive/macBinary).

ConfidenceProgramDetectionMatch TypeSupport
66% dexvert Compact Compressed (Unix) (archive/compact) ext Supported
10% dexvert MacBinary (archive/macBinary) fallback Supported
1% dexvert Text File (text/txt) fallback Supported
100% file MacBinary II, inited, Wed Jul 28 18:55:36 1993, modified Wed Jul 28 18:55:36 1993, creator 'MPS ', type ASCII, 10727 bytes "CONES.C" , at 0x2a67 428 bytes resource default (weak)
99% file data default
74% TrID Macintosh plain text (MacBinary) default
25% TrID MacBinary 2 default (weak)
100% lsar MacBinary default


id metadata
keyvalue
macFileType[TEXT]
macFileCreator[MPS ]



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 07 43 4f 4e 45 53 2e | 43 00 00 00 00 00 00 00 |..CONES.|C.......|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 4d 50 53 | 20 01 00 00 00 00 00 00 |.TEXTMPS| .......|
|00000050| 00 00 00 00 00 29 e7 00 | 00 01 ac a8 7c b4 68 a8 |.....)..|....|.h.|
|00000060| 7c b4 68 00 00 08 00 00 | 00 00 00 00 00 00 00 00 ||.h.....|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 a8 1c 00 00 |........|........|
|00000080| 2f 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |/*******|********|
|00000090| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000000a0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000000b0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000000c0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 0d 2a 20 |********|*****.* |
|000000d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 63 | | c|
|000000e0| 6f 6e 65 73 2e 63 0d 2a | 0d 2a 20 20 54 68 69 73 |ones.c.*|.* This|
|000000f0| 20 6d 6f 64 75 6c 65 20 | 69 6d 70 6c 65 6d 65 6e | module |implemen|
|00000100| 74 73 20 74 68 65 20 63 | 6f 6e 65 20 70 72 69 6d |ts the c|one prim|
|00000110| 69 74 69 76 65 2e 0d 2a | 20 20 54 68 69 73 20 66 |itive..*| This f|
|00000120| 69 6c 65 20 77 61 73 20 | 77 72 69 74 74 65 6e 20 |ile was |written |
|00000130| 62 79 20 41 6c 65 78 61 | 6e 64 65 72 20 45 6e 7a |by Alexa|nder Enz|
|00000140| 6d 61 6e 6e 2e 20 20 20 | 20 48 65 20 77 72 6f 74 |mann. | He wrot|
|00000150| 65 20 74 68 65 20 63 6f | 64 65 20 66 6f 72 0d 2a |e the co|de for.*|
|00000160| 20 20 63 6f 6e 65 73 20 | 61 6e 64 20 67 65 6e 65 | cones |and gene|
|00000170| 72 6f 75 73 6c 79 20 70 | 72 6f 76 69 64 65 64 20 |rously p|rovided |
|00000180| 75 73 20 74 68 65 73 65 | 20 65 6e 68 61 6e 63 65 |us these| enhance|
|00000190| 6d 65 6e 74 73 2e 0d 2a | 0d 2a 20 20 66 72 6f 6d |ments..*|.* from|
|000001a0| 20 50 65 72 73 69 73 74 | 65 6e 63 65 20 6f 66 20 | Persist|ence of |
|000001b0| 56 69 73 69 6f 6e 20 52 | 61 79 74 72 61 63 65 72 |Vision R|aytracer|
|000001c0| 0d 2a 20 20 43 6f 70 79 | 72 69 67 68 74 20 31 39 |.* Copy|right 19|
|000001d0| 39 33 20 50 65 72 73 69 | 73 74 65 6e 63 65 20 6f |93 Persi|stence o|
|000001e0| 66 20 56 69 73 69 6f 6e | 20 54 65 61 6d 0d 2a 2d |f Vision| Team.*-|
|000001f0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000200| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000210| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000220| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00000230| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 0d 2a 20 20 4e 4f |--------|--.* NO|
|00000240| 54 49 43 45 3a 20 54 68 | 69 73 20 73 6f 75 72 63 |TICE: Th|is sourc|
|00000250| 65 20 63 6f 64 65 20 66 | 69 6c 65 20 69 73 20 70 |e code f|ile is p|
|00000260| 72 6f 76 69 64 65 64 20 | 73 6f 20 74 68 61 74 20 |rovided |so that |
|00000270| 75 73 65 72 73 20 6d 61 | 79 20 65 78 70 65 72 69 |users ma|y experi|
|00000280| 6d 65 6e 74 0d 2a 20 20 | 77 69 74 68 20 65 6e 68 |ment.* |with enh|
|00000290| 61 6e 63 65 6d 65 6e 74 | 73 20 74 6f 20 50 4f 56 |ancement|s to POV|
|000002a0| 2d 52 61 79 20 61 6e 64 | 20 74 6f 20 70 6f 72 74 |-Ray and| to port|
|000002b0| 20 74 68 65 20 73 6f 66 | 74 77 61 72 65 20 74 6f | the sof|tware to|
|000002c0| 20 70 6c 61 74 66 6f 72 | 6d 73 20 6f 74 68 65 72 | platfor|ms other|
|000002d0| 20 0d 2a 20 20 74 68 61 | 6e 20 74 68 6f 73 65 20 | .* tha|n those |
|000002e0| 73 75 70 70 6f 72 74 65 | 64 20 62 79 20 74 68 65 |supporte|d by the|
|000002f0| 20 50 4f 56 2d 52 61 79 | 20 54 65 61 6d 2e 20 20 | POV-Ray| Team. |
|00000300| 54 68 65 72 65 20 61 72 | 65 20 73 74 72 69 63 74 |There ar|e strict|
|00000310| 20 72 75 6c 65 73 20 75 | 6e 64 65 72 0d 2a 20 20 | rules u|nder.* |
|00000320| 77 68 69 63 68 20 79 6f | 75 20 61 72 65 20 70 65 |which yo|u are pe|
|00000330| 72 6d 69 74 74 65 64 20 | 74 6f 20 75 73 65 20 74 |rmitted |to use t|
|00000340| 68 69 73 20 66 69 6c 65 | 2e 20 20 54 68 65 20 72 |his file|. The r|
|00000350| 75 6c 65 73 20 61 72 65 | 20 69 6e 20 74 68 65 20 |ules are| in the |
|00000360| 66 69 6c 65 0d 2a 20 20 | 6e 61 6d 65 64 20 50 4f |file.* |named PO|
|00000370| 56 4c 45 47 41 4c 2e 44 | 4f 43 20 77 68 69 63 68 |VLEGAL.D|OC which|
|00000380| 20 73 68 6f 75 6c 64 20 | 62 65 20 64 69 73 74 72 | should |be distr|
|00000390| 69 62 75 74 65 64 20 77 | 69 74 68 20 74 68 69 73 |ibuted w|ith this|
|000003a0| 20 66 69 6c 65 2e 20 49 | 66 20 0d 2a 20 20 50 4f | file. I|f .* PO|
|000003b0| 56 4c 45 47 41 4c 2e 44 | 4f 43 20 69 73 20 6e 6f |VLEGAL.D|OC is no|
|000003c0| 74 20 61 76 61 69 6c 61 | 62 6c 65 20 6f 72 20 66 |t availa|ble or f|
|000003d0| 6f 72 20 6d 6f 72 65 20 | 69 6e 66 6f 20 70 6c 65 |or more |info ple|
|000003e0| 61 73 65 20 63 6f 6e 74 | 61 63 74 20 74 68 65 20 |ase cont|act the |
|000003f0| 50 4f 56 2d 52 61 79 0d | 2a 20 20 54 65 61 6d 20 |POV-Ray.|* Team |
|00000400| 43 6f 6f 72 64 69 6e 61 | 74 6f 72 20 62 79 20 6c |Coordina|tor by l|
|00000410| 65 61 76 69 6e 67 20 61 | 20 6d 65 73 73 61 67 65 |eaving a| message|
|00000420| 20 69 6e 20 43 6f 6d 70 | 75 53 65 72 76 65 27 73 | in Comp|uServe's|
|00000430| 20 47 72 61 70 68 69 63 | 73 20 44 65 76 65 6c 6f | Graphic|s Develo|
|00000440| 70 65 72 27 73 0d 2a 20 | 20 46 6f 72 75 6d 2e 20 |per's.* | Forum. |
|00000450| 20 54 68 65 20 6c 61 74 | 65 73 74 20 76 65 72 73 | The lat|est vers|
|00000460| 69 6f 6e 20 6f 66 20 50 | 4f 56 2d 52 61 79 20 6d |ion of P|OV-Ray m|
|00000470| 61 79 20 62 65 20 66 6f | 75 6e 64 20 74 68 65 72 |ay be fo|und ther|
|00000480| 65 20 61 73 20 77 65 6c | 6c 2e 0d 2a 0d 2a 20 54 |e as wel|l..*.* T|
|00000490| 68 69 73 20 70 72 6f 67 | 72 61 6d 20 69 73 20 62 |his prog|ram is b|
|000004a0| 61 73 65 64 20 6f 6e 20 | 74 68 65 20 70 6f 70 75 |ased on |the popu|
|000004b0| 6c 61 72 20 44 4b 42 20 | 72 61 79 74 72 61 63 65 |lar DKB |raytrace|
|000004c0| 72 20 76 65 72 73 69 6f | 6e 20 32 2e 31 32 2e 0d |r versio|n 2.12..|
|000004d0| 2a 20 44 4b 42 54 72 61 | 63 65 20 77 61 73 20 6f |* DKBTra|ce was o|
|000004e0| 72 69 67 69 6e 61 6c 6c | 79 20 77 72 69 74 74 65 |riginall|y writte|
|000004f0| 6e 20 62 79 20 44 61 76 | 69 64 20 4b 2e 20 42 75 |n by Dav|id K. Bu|
|00000500| 63 6b 2e 0d 2a 20 44 4b | 42 54 72 61 63 65 20 56 |ck..* DK|BTrace V|
|00000510| 65 72 20 32 2e 30 2d 32 | 2e 31 32 20 77 65 72 65 |er 2.0-2|.12 were|
|00000520| 20 77 72 69 74 74 65 6e | 20 62 79 20 44 61 76 69 | written| by Davi|
|00000530| 64 20 4b 2e 20 42 75 63 | 6b 20 26 20 41 61 72 6f |d K. Buc|k & Aaro|
|00000540| 6e 20 41 2e 20 43 6f 6c | 6c 69 6e 73 2e 0d 2a 0d |n A. Col|lins..*.|
|00000550| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000560| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000570| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000580| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000590| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2f 0d 0d |********|*****/..|
|000005a0| 23 69 6e 63 6c 75 64 65 | 20 22 66 72 61 6d 65 2e |#include| "frame.|
|000005b0| 68 22 0d 23 69 6e 63 6c | 75 64 65 20 22 76 65 63 |h".#incl|ude "vec|
|000005c0| 74 6f 72 2e 68 22 0d 23 | 69 6e 63 6c 75 64 65 20 |tor.h".#|include |
|000005d0| 22 70 6f 76 70 72 6f 74 | 6f 2e 68 22 0d 0d 4d 45 |"povprot|o.h"..ME|
|000005e0| 54 48 4f 44 53 20 43 6f | 6e 65 5f 4d 65 74 68 6f |THODS Co|ne_Metho|
|000005f0| 64 73 20 3d 0d 20 20 7b | 20 0d 20 20 41 6c 6c 5f |ds =. {| . All_|
|00000600| 43 6f 6e 65 5f 49 6e 74 | 65 72 73 65 63 74 69 6f |Cone_Int|ersectio|
|00000610| 6e 73 2c 0d 20 20 49 6e | 73 69 64 65 5f 43 6f 6e |ns,. In|side_Con|
|00000620| 65 2c 20 43 6f 6e 65 5f | 4e 6f 72 6d 61 6c 2c 0d |e, Cone_|Normal,.|
|00000630| 20 20 43 6f 70 79 5f 43 | 6f 6e 65 2c 20 54 72 61 | Copy_C|one, Tra|
|00000640| 6e 73 6c 61 74 65 5f 43 | 6f 6e 65 2c 20 52 6f 74 |nslate_C|one, Rot|
|00000650| 61 74 65 5f 43 6f 6e 65 | 2c 20 53 63 61 6c 65 5f |ate_Cone|, Scale_|
|00000660| 43 6f 6e 65 2c 20 54 72 | 61 6e 73 66 6f 72 6d 5f |Cone, Tr|ansform_|
|00000670| 43 6f 6e 65 2c 0d 20 20 | 49 6e 76 65 72 74 5f 43 |Cone,. |Invert_C|
|00000680| 6f 6e 65 2c 20 44 65 73 | 74 72 6f 79 5f 43 6f 6e |one, Des|troy_Con|
|00000690| 65 0d 20 20 7d 3b 0d 0d | 65 78 74 65 72 6e 20 6c |e. };..|extern l|
|000006a0| 6f 6e 67 20 52 61 79 5f | 43 6f 6e 65 5f 54 65 73 |ong Ray_|Cone_Tes|
|000006b0| 74 73 2c 20 52 61 79 5f | 43 6f 6e 65 5f 54 65 73 |ts, Ray_|Cone_Tes|
|000006c0| 74 73 5f 53 75 63 63 65 | 65 64 65 64 3b 0d 73 74 |ts_Succe|eded;.st|
|000006d0| 61 74 69 63 20 69 6e 74 | 20 49 6e 74 65 72 73 65 |atic int| Interse|
|000006e0| 63 74 5f 43 6f 6e 65 20 | 50 41 52 41 4d 53 28 28 |ct_Cone |PARAMS((|
|000006f0| 52 41 59 20 2a 52 61 79 | 2c 20 43 4f 4e 45 20 2a |RAY *Ray|, CONE *|
|00000700| 43 6f 6e 65 2c 20 44 42 | 4c 20 2a 44 65 70 74 68 |Cone, DB|L *Depth|
|00000710| 73 29 29 3b 0d 0d 23 69 | 66 6e 64 65 66 20 43 6f |s));..#i|fndef Co|
|00000720| 6e 65 5f 54 6f 6c 65 72 | 61 6e 63 65 0d 23 64 65 |ne_Toler|ance.#de|
|00000730| 66 69 6e 65 20 43 6f 6e | 65 5f 54 6f 6c 65 72 61 |fine Con|e_Tolera|
|00000740| 6e 63 65 20 31 2e 30 65 | 2d 36 0d 23 65 6e 64 69 |nce 1.0e|-6.#endi|
|00000750| 66 0d 0d 23 64 65 66 69 | 6e 65 20 63 6c 6f 73 65 |f..#defi|ne close|
|00000760| 28 78 2c 20 79 29 20 28 | 66 61 62 73 28 78 2d 79 |(x, y) (|fabs(x-y|
|00000770| 29 20 3c 20 45 50 53 49 | 4c 4f 4e 20 3f 20 31 20 |) < EPSI|LON ? 1 |
|00000780| 3a 20 30 29 0d 0d 69 6e | 74 20 41 6c 6c 5f 43 6f |: 0)..in|t All_Co|
|00000790| 6e 65 5f 49 6e 74 65 72 | 73 65 63 74 69 6f 6e 73 |ne_Inter|sections|
|000007a0| 20 28 4f 62 6a 65 63 74 | 2c 20 52 61 79 2c 20 44 | (Object|, Ray, D|
|000007b0| 65 70 74 68 5f 53 74 61 | 63 6b 29 0d 4f 42 4a 45 |epth_Sta|ck).OBJE|
|000007c0| 43 54 20 2a 4f 62 6a 65 | 63 74 3b 0d 52 41 59 20 |CT *Obje|ct;.RAY |
|000007d0| 2a 52 61 79 3b 0d 49 53 | 54 41 43 4b 20 2a 44 65 |*Ray;.IS|TACK *De|
|000007e0| 70 74 68 5f 53 74 61 63 | 6b 3b 0d 20 20 7b 0d 20 |pth_Stac|k;. {. |
|000007f0| 20 44 42 4c 20 44 65 70 | 74 68 73 5b 34 5d 3b 0d | DBL Dep|ths[4];.|
|00000800| 20 20 56 45 43 54 4f 52 | 20 49 50 6f 69 6e 74 3b | VECTOR| IPoint;|
|00000810| 0d 20 20 69 6e 74 20 49 | 6e 74 65 72 73 65 63 74 |. int I|ntersect|
|00000820| 69 6f 6e 5f 46 6f 75 6e | 64 2c 20 63 6e 74 2c 20 |ion_Foun|d, cnt, |
|00000830| 69 3b 0d 0d 20 20 49 6e | 74 65 72 73 65 63 74 69 |i;.. In|tersecti|
|00000840| 6f 6e 5f 46 6f 75 6e 64 | 20 3d 20 46 41 4c 53 45 |on_Found| = FALSE|
|00000850| 3b 0d 0d 20 20 69 66 20 | 28 28 63 6e 74 3d 49 6e |;.. if |((cnt=In|
|00000860| 74 65 72 73 65 63 74 5f | 43 6f 6e 65 20 28 52 61 |tersect_|Cone (Ra|
|00000870| 79 2c 20 28 43 4f 4e 45 | 20 2a 29 4f 62 6a 65 63 |y, (CONE| *)Objec|
|00000880| 74 2c 20 44 65 70 74 68 | 73 29 29 21 3d 30 29 0d |t, Depth|s))!=0).|
|00000890| 20 20 20 20 66 6f 72 20 | 28 69 3d 30 3b 20 69 3c | for |(i=0; i<|
|000008a0| 63 6e 74 3b 20 69 2b 2b | 29 0d 20 20 20 20 7b 0d |cnt; i++|). {.|
|000008b0| 20 20 20 20 56 53 63 61 | 6c 65 20 28 49 50 6f 69 | VSca|le (IPoi|
|000008c0| 6e 74 2c 20 52 61 79 2d | 3e 44 69 72 65 63 74 69 |nt, Ray-|>Directi|
|000008d0| 6f 6e 2c 20 44 65 70 74 | 68 73 5b 69 5d 29 3b 0d |on, Dept|hs[i]);.|
|000008e0| 20 20 20 20 56 41 64 64 | 45 71 20 28 49 50 6f 69 | VAdd|Eq (IPoi|
|000008f0| 6e 74 2c 20 52 61 79 2d | 3e 49 6e 69 74 69 61 6c |nt, Ray-|>Initial|
|00000900| 29 3b 0d 0d 20 20 20 20 | 69 66 20 28 50 6f 69 6e |);.. |if (Poin|
|00000910| 74 5f 49 6e 5f 43 6c 69 | 70 20 28 26 49 50 6f 69 |t_In_Cli|p (&IPoi|
|00000920| 6e 74 2c 20 4f 62 6a 65 | 63 74 2d 3e 43 6c 69 70 |nt, Obje|ct->Clip|
|00000930| 29 29 0d 20 20 20 20 20 | 20 7b 0d 20 20 20 20 20 |)). | {. |
|00000940| 20 70 75 73 68 5f 65 6e | 74 72 79 28 44 65 70 74 | push_en|try(Dept|
|00000950| 68 73 5b 69 5d 2c 49 50 | 6f 69 6e 74 2c 4f 62 6a |hs[i],IP|oint,Obj|
|00000960| 65 63 74 2c 44 65 70 74 | 68 5f 53 74 61 63 6b 29 |ect,Dept|h_Stack)|
|00000970| 3b 0d 20 20 20 20 20 20 | 49 6e 74 65 72 73 65 63 |;. |Intersec|
|00000980| 74 69 6f 6e 5f 46 6f 75 | 6e 64 20 3d 20 54 52 55 |tion_Fou|nd = TRU|
|00000990| 45 3b 0d 20 20 20 20 20 | 20 7d 0d 20 20 20 20 7d |E;. | }. }|
|000009a0| 0d 20 20 72 65 74 75 72 | 6e 20 28 49 6e 74 65 72 |. retur|n (Inter|
|000009b0| 73 65 63 74 69 6f 6e 5f | 46 6f 75 6e 64 29 3b 0d |section_|Found);.|
|000009c0| 20 20 7d 0d 0d 73 74 61 | 74 69 63 20 69 6e 74 20 | }..sta|tic int |
|000009d0| 49 6e 74 65 72 73 65 63 | 74 5f 43 6f 6e 65 20 28 |Intersec|t_Cone (|
|000009e0| 52 61 79 2c 20 43 6f 6e | 65 2c 20 44 65 70 74 68 |Ray, Con|e, Depth|
|000009f0| 73 29 0d 52 41 59 20 2a | 52 61 79 3b 0d 43 4f 4e |s).RAY *|Ray;.CON|
|00000a00| 45 20 2a 43 6f 6e 65 3b | 0d 44 42 4c 20 2a 44 65 |E *Cone;|.DBL *De|
|00000a10| 70 74 68 73 3b 0d 20 20 | 7b 0d 20 20 44 42 4c 20 |pths;. |{. DBL |
|00000a20| 61 2c 20 62 2c 20 63 2c | 20 7a 2c 20 74 31 2c 20 |a, b, c,| z, t1, |
|00000a30| 74 32 2c 20 6c 65 6e 3b | 0d 20 20 44 42 4c 20 64 |t2, len;|. DBL d|
|00000a40| 3b 0d 20 20 56 45 43 54 | 4f 52 20 50 2c 20 44 3b |;. VECT|OR P, D;|
|00000a50| 0d 20 20 69 6e 74 20 69 | 3d 30 3b 0d 0d 20 20 52 |. int i|=0;.. R|
|00000a60| 61 79 5f 43 6f 6e 65 5f | 54 65 73 74 73 2b 2b 3b |ay_Cone_|Tests++;|
|00000a70| 0d 0d 20 20 2f 2a 20 54 | 72 61 6e 73 66 6f 72 6d |.. /* T|ransform|
|00000a80| 20 74 68 65 20 72 61 79 | 20 69 6e 74 6f 20 74 68 | the ray| into th|
|00000a90| 65 20 63 6f 6e 65 73 20 | 73 70 61 63 65 20 2a 2f |e cones |space */|
|00000aa0| 0d 20 20 4d 49 6e 76 54 | 72 61 6e 73 50 6f 69 6e |. MInvT|ransPoin|
|00000ab0| 74 28 26 50 2c 20 26 52 | 61 79 2d 3e 49 6e 69 74 |t(&P, &R|ay->Init|
|00000ac0| 69 61 6c 2c 20 43 6f 6e | 65 2d 3e 54 72 61 6e 73 |ial, Con|e->Trans|
|00000ad0| 29 3b 0d 20 20 4d 49 6e | 76 54 72 61 6e 73 44 69 |);. MIn|vTransDi|
|00000ae0| 72 65 63 74 69 6f 6e 28 | 26 44 2c 20 26 52 61 79 |rection(|&D, &Ray|
|00000af0| 2d 3e 44 69 72 65 63 74 | 69 6f 6e 2c 20 43 6f 6e |->Direct|ion, Con|
|00000b00| 65 2d 3e 54 72 61 6e 73 | 29 3b 0d 0d 20 20 56 4c |e->Trans|);.. VL|
|00000b10| 65 6e 67 74 68 28 6c 65 | 6e 2c 20 44 29 3b 0d 20 |ength(le|n, D);. |
|00000b20| 20 56 49 6e 76 65 72 73 | 65 53 63 61 6c 65 45 71 | VInvers|eScaleEq|
|00000b30| 28 44 2c 20 6c 65 6e 29 | 3b 0d 0d 20 20 69 66 20 |(D, len)|;.. if |
|00000b40| 28 43 6f 6e 65 2d 3e 63 | 79 6c 5f 66 6c 61 67 29 |(Cone->c|yl_flag)|
|00000b50| 20 0d 20 20 20 20 7b 0d | 20 20 20 20 2f 2a 20 53 | . {.| /* S|
|00000b60| 6f 6c 76 65 20 69 6e 74 | 65 72 73 65 63 74 69 6f |olve int|ersectio|
|00000b70| 6e 73 20 77 69 74 68 20 | 61 20 63 79 6c 69 6e 64 |ns with |a cylind|
|00000b80| 65 72 20 2a 2f 0d 20 20 | 20 20 61 20 3d 20 44 2e |er */. | a = D.|
|00000b90| 78 20 2a 20 44 2e 78 20 | 2b 20 44 2e 79 20 2a 20 |x * D.x |+ D.y * |
|00000ba0| 44 2e 79 3b 0d 20 20 20 | 20 69 66 20 28 61 20 3e |D.y;. | if (a >|
|00000bb0| 20 45 50 53 49 4c 4f 4e | 29 20 0d 20 20 20 20 20 | EPSILON|) . |
|00000bc0| 20 7b 0d 20 20 20 20 20 | 20 62 20 3d 20 50 2e 78 | {. | b = P.x|
|00000bd0| 20 2a 20 44 2e 78 20 2b | 20 50 2e 79 20 2a 20 44 | * D.x +| P.y * D|
|00000be0| 2e 79 3b 0d 20 20 20 20 | 20 20 63 20 3d 20 50 2e |.y;. | c = P.|
|00000bf0| 78 20 2a 20 50 2e 78 20 | 2b 20 50 2e 79 20 2a 20 |x * P.x |+ P.y * |
|00000c00| 50 2e 79 20 2d 20 31 2e | 30 3b 0d 20 20 20 20 20 |P.y - 1.|0;. |
|00000c10| 20 64 20 3d 20 62 20 2a | 20 62 20 2d 20 61 20 2a | d = b *| b - a *|
|00000c20| 20 63 3b 0d 20 20 20 20 | 20 20 69 66 20 28 64 20 | c;. | if (d |
|00000c30| 3e 3d 20 30 2e 30 29 0d | 20 20 20 20 20 20 20 20 |>= 0.0).| |
|00000c40| 7b 0d 20 20 20 20 20 20 | 20 20 64 20 3d 20 73 71 |{. | d = sq|
|00000c50| 72 74 28 64 29 3b 0d 20 | 20 20 20 20 20 20 20 74 |rt(d);. | t|
|00000c60| 31 20 3d 20 28 2d 62 20 | 2b 20 64 29 20 2f 20 61 |1 = (-b |+ d) / a|
|00000c70| 3b 0d 20 20 20 20 20 20 | 20 20 74 32 20 3d 20 28 |;. | t2 = (|
|00000c80| 2d 62 20 2d 20 64 29 20 | 2f 20 61 3b 0d 20 20 20 |-b - d) |/ a;. |
|00000c90| 20 20 20 20 20 7a 20 3d | 20 50 2e 7a 20 2b 20 74 | z =| P.z + t|
|00000ca0| 31 20 2a 20 44 2e 7a 3b | 0d 20 20 20 20 20 20 20 |1 * D.z;|. |
|00000cb0| 20 69 66 20 28 74 31 20 | 3e 20 43 6f 6e 65 5f 54 | if (t1 |> Cone_T|
|00000cc0| 6f 6c 65 72 61 6e 63 65 | 20 26 26 20 74 31 20 3c |olerance| && t1 <|
|00000cd0| 20 4d 61 78 5f 44 69 73 | 74 61 6e 63 65 20 26 26 | Max_Dis|tance &&|
|00000ce0| 20 7a 20 3e 3d 20 30 2e | 30 20 26 26 20 7a 20 3c | z >= 0.|0 && z <|
|00000cf0| 3d 20 31 2e 30 29 0d 20 | 20 20 20 20 20 20 20 20 |= 1.0). | |
|00000d00| 20 44 65 70 74 68 73 5b | 69 2b 2b 5d 20 3d 20 74 | Depths[|i++] = t|
|00000d10| 31 2f 6c 65 6e 3b 0d 20 | 20 20 20 20 20 20 20 7a |1/len;. | z|
|00000d20| 20 3d 20 50 2e 7a 20 2b | 20 74 32 20 2a 20 44 2e | = P.z +| t2 * D.|
|00000d30| 7a 3b 0d 20 20 20 20 20 | 20 20 20 69 66 20 28 74 |z;. | if (t|
|00000d40| 32 20 3e 20 43 6f 6e 65 | 5f 54 6f 6c 65 72 61 6e |2 > Cone|_Toleran|
|00000d50| 63 65 20 26 26 20 74 31 | 20 3c 20 4d 61 78 5f 44 |ce && t1| < Max_D|
|00000d60| 69 73 74 61 6e 63 65 20 | 26 26 20 7a 20 3e 3d 20 |istance |&& z >= |
|00000d70| 30 2e 30 20 26 26 20 7a | 20 3c 3d 20 31 2e 30 29 |0.0 && z| <= 1.0)|
|00000d80| 0d 20 20 20 20 20 20 20 | 20 20 20 44 65 70 74 68 |. | Depth|
|00000d90| 73 5b 69 2b 2b 5d 20 3d | 20 74 32 2f 6c 65 6e 3b |s[i++] =| t2/len;|
|00000da0| 0d 20 20 20 20 20 20 20 | 20 7d 0d 20 20 20 20 20 |. | }. |
|00000db0| 20 7d 0d 20 20 20 20 7d | 0d 20 20 65 6c 73 65 0d | }. }|. else.|
|00000dc0| 20 20 20 20 7b 0d 20 20 | 20 20 2f 2a 20 53 6f 6c | {. | /* Sol|
|00000dd0| 76 65 20 69 6e 74 65 72 | 73 65 63 74 69 6f 6e 73 |ve inter|sections|
|00000de0| 20 77 69 74 68 20 61 20 | 63 6f 6e 65 20 2a 2f 0d | with a |cone */.|
|00000df0| 20 20 20 20 61 20 3d 20 | 44 2e 78 20 2a 20 44 2e | a = |D.x * D.|
|00000e00| 78 20 2b 20 44 2e 79 20 | 2a 20 44 2e 79 20 2d 20 |x + D.y |* D.y - |
|00000e10| 44 2e 7a 20 2a 20 44 2e | 7a 3b 0d 20 20 20 20 62 |D.z * D.|z;. b|
|00000e20| 20 3d 20 44 2e 78 20 2a | 20 50 2e 78 20 2b 20 44 | = D.x *| P.x + D|
|00000e30| 2e 79 20 2a 20 50 2e 79 | 20 2d 20 44 2e 7a 20 2a |.y * P.y| - D.z *|
|00000e40| 20 50 2e 7a 3b 0d 20 20 | 20 20 63 20 3d 20 50 2e | P.z;. | c = P.|
|00000e50| 78 20 2a 20 50 2e 78 20 | 2b 20 50 2e 79 20 2a 20 |x * P.x |+ P.y * |
|00000e60| 50 2e 79 20 2d 20 50 2e | 7a 20 2a 20 50 2e 7a 3b |P.y - P.|z * P.z;|
|00000e70| 0d 0d 20 20 20 20 69 66 | 20 28 66 61 62 73 28 61 |.. if| (fabs(a|
|00000e80| 29 20 3c 20 45 50 53 49 | 4c 4f 4e 29 0d 20 20 20 |) < EPSI|LON). |
|00000e90| 20 20 20 7b 0d 20 20 20 | 20 20 20 69 66 20 28 66 | {. | if (f|
|00000ea0| 61 62 73 28 62 29 20 3e | 20 45 50 53 49 4c 4f 4e |abs(b) >| EPSILON|
|00000eb0| 29 0d 20 20 20 20 20 20 | 20 20 7b 0d 20 20 20 20 |). | {. |
|00000ec0| 20 20 20 20 2f 2a 20 4f | 6e 65 20 69 6e 74 65 72 | /* O|ne inter|
|00000ed0| 73 65 63 74 69 6f 6e 20 | 2a 2f 0d 20 20 20 20 20 |section |*/. |
|00000ee0| 20 20 20 74 31 20 3d 20 | 2d 30 2e 35 20 2a 20 63 | t1 = |-0.5 * c|
|00000ef0| 20 2f 20 62 3b 0d 20 20 | 20 20 20 20 20 20 7a 20 | / b;. | z |
|00000f00| 3d 20 50 2e 7a 20 2b 20 | 74 31 20 2a 20 44 2e 7a |= P.z + |t1 * D.z|
|00000f10| 3b 0d 20 20 20 20 20 20 | 20 20 69 66 20 28 74 31 |;. | if (t1|
|00000f20| 20 3e 20 43 6f 6e 65 5f | 54 6f 6c 65 72 61 6e 63 | > Cone_|Toleranc|
|00000f30| 65 20 26 26 20 74 31 20 | 3c 20 4d 61 78 5f 44 69 |e && t1 |< Max_Di|
|00000f40| 73 74 61 6e 63 65 20 26 | 26 20 7a 20 3e 3d 20 43 |stance &|& z >= C|
|00000f50| 6f 6e 65 2d 3e 64 69 73 | 74 20 26 26 20 7a 20 3c |one->dis|t && z <|
|00000f60| 3d 20 31 2e 30 29 0d 20 | 20 20 20 20 20 20 20 20 |= 1.0). | |
|00000f70| 20 44 65 70 74 68 73 5b | 69 2b 2b 5d 20 3d 20 74 | Depths[|i++] = t|
|00000f80| 31 2f 6c 65 6e 3b 0d 20 | 20 20 20 20 20 20 20 7d |1/len;. | }|
|00000f90| 0d 20 20 20 20 20 20 7d | 0d 20 20 20 20 65 6c 73 |. }|. els|
|00000fa0| 65 0d 20 20 20 20 20 20 | 7b 0d 20 20 20 20 20 20 |e. |{. |
|00000fb0| 2f 2a 20 43 68 65 63 6b | 20 68 69 74 73 20 61 67 |/* Check| hits ag|
|00000fc0| 61 69 6e 73 74 20 74 68 | 65 20 73 69 64 65 20 6f |ainst th|e side o|
|00000fd0| 66 20 74 68 65 20 63 6f | 6e 65 20 2a 2f 0d 20 20 |f the co|ne */. |
|00000fe0| 20 20 20 20 64 20 3d 20 | 62 20 2a 20 62 20 2d 20 | d = |b * b - |
|00000ff0| 61 20 2a 20 63 3b 0d 20 | 20 20 20 20 20 69 66 20 |a * c;. | if |
|00001000| 28 64 20 3e 3d 20 30 2e | 30 29 0d 20 20 20 20 20 |(d >= 0.|0). |
|00001010| 20 20 20 7b 0d 20 20 20 | 20 20 20 20 20 64 20 3d | {. | d =|
|00001020| 20 73 71 72 74 28 64 29 | 3b 0d 20 20 20 20 20 20 | sqrt(d)|;. |
|00001030| 20 20 74 31 20 3d 20 28 | 2d 62 20 2d 20 64 29 20 | t1 = (|-b - d) |
|00001040| 2f 20 61 3b 0d 20 20 20 | 20 20 20 20 20 74 32 20 |/ a;. | t2 |
|00001050| 3d 20 28 2d 62 20 2b 20 | 64 29 20 2f 20 61 3b 0d |= (-b + |d) / a;.|
|00001060| 20 20 20 20 20 20 20 20 | 7a 20 3d 20 50 2e 7a 20 | |z = P.z |
|00001070| 2b 20 74 31 20 2a 20 44 | 2e 7a 3b 0d 20 20 20 20 |+ t1 * D|.z;. |
|00001080| 20 20 20 20 69 66 20 28 | 74 31 20 3e 20 43 6f 6e | if (|t1 > Con|
|00001090| 65 5f 54 6f 6c 65 72 61 | 6e 63 65 20 26 26 20 74 |e_Tolera|nce && t|
|000010a0| 31 20 3c 20 4d 61 78 5f | 44 69 73 74 61 6e 63 65 |1 < Max_|Distance|
|000010b0| 20 26 26 20 7a 20 3e 3d | 20 43 6f 6e 65 2d 3e 64 | && z >=| Cone->d|
|000010c0| 69 73 74 20 26 26 20 7a | 20 3c 3d 20 31 2e 30 29 |ist && z| <= 1.0)|
|000010d0| 0d 20 20 20 20 20 20 20 | 20 20 20 44 65 70 74 68 |. | Depth|
|000010e0| 73 5b 69 2b 2b 5d 20 3d | 20 74 31 2f 6c 65 6e 3b |s[i++] =| t1/len;|
|000010f0| 0d 20 20 20 20 20 20 20 | 20 7a 20 3d 20 50 2e 7a |. | z = P.z|
|00001100| 20 2b 20 74 32 20 2a 20 | 44 2e 7a 3b 0d 20 20 20 | + t2 * |D.z;. |
|00001110| 20 20 20 20 20 69 66 20 | 28 74 32 20 3e 20 43 6f | if |(t2 > Co|
|00001120| 6e 65 5f 54 6f 6c 65 72 | 61 6e 63 65 20 26 26 20 |ne_Toler|ance && |
|00001130| 74 31 20 3c 20 4d 61 78 | 5f 44 69 73 74 61 6e 63 |t1 < Max|_Distanc|
|00001140| 65 20 26 26 20 7a 20 3e | 3d 20 43 6f 6e 65 2d 3e |e && z >|= Cone->|
|00001150| 64 69 73 74 20 26 26 20 | 7a 20 3c 3d 20 31 2e 30 |dist && |z <= 1.0|
|00001160| 29 0d 20 20 20 20 20 20 | 20 20 20 20 44 65 70 74 |). | Dept|
|00001170| 68 73 5b 69 2b 2b 5d 20 | 3d 20 74 32 2f 6c 65 6e |hs[i++] |= t2/len|
|00001180| 3b 0d 20 20 20 20 20 20 | 20 20 7d 0d 20 20 20 20 |;. | }. |
|00001190| 20 20 7d 0d 20 20 20 20 | 7d 0d 0d 20 20 69 66 20 | }. |}.. if |
|000011a0| 28 43 6f 6e 65 2d 3e 63 | 6c 6f 73 65 64 29 0d 20 |(Cone->c|losed). |
|000011b0| 20 20 20 7b 0d 20 20 20 | 20 64 20 3d 20 28 31 2e | {. | d = (1.|
|000011c0| 30 20 2d 20 50 2e 7a 29 | 20 2f 20 44 2e 7a 3b 0d |0 - P.z)| / D.z;.|
|000011d0| 20 20 20 20 61 20 3d 20 | 28 50 2e 78 20 2b 20 64 | a = |(P.x + d|
|000011e0| 20 2a 20 44 2e 78 29 3b | 0d 20 20 20 20 62 20 3d | * D.x);|. b =|
|000011f0| 20 28 50 2e 79 20 2b 20 | 64 20 2a 20 44 2e 79 29 | (P.y + |d * D.y)|
|00001200| 3b 0d 20 20 20 20 69 66 | 20 28 28 61 20 2a 20 61 |;. if| ((a * a|
|00001210| 20 2b 20 62 20 2a 20 62 | 29 20 3c 3d 20 31 2e 30 | + b * b|) <= 1.0|
|00001220| 20 26 26 20 64 20 3e 20 | 43 6f 6e 65 5f 54 6f 6c | && d > |Cone_Tol|
|00001230| 65 72 61 6e 63 65 20 26 | 26 20 64 20 3c 20 4d 61 |erance &|& d < Ma|
|00001240| 78 5f 44 69 73 74 61 6e | 63 65 29 0d 20 20 20 20 |x_Distan|ce). |
|00001250| 20 20 44 65 70 74 68 73 | 5b 69 2b 2b 5d 20 3d 20 | Depths|[i++] = |
|00001260| 64 2f 6c 65 6e 3b 0d 20 | 20 20 20 64 20 3d 20 28 |d/len;. | d = (|
|00001270| 43 6f 6e 65 2d 3e 64 69 | 73 74 20 2d 20 50 2e 7a |Cone->di|st - P.z|
|00001280| 29 20 2f 20 44 2e 7a 3b | 0d 20 20 20 20 61 20 3d |) / D.z;|. a =|
|00001290| 20 28 50 2e 78 20 2b 20 | 64 20 2a 20 44 2e 78 29 | (P.x + |d * D.x)|
|000012a0| 3b 0d 20 20 20 20 62 20 | 3d 20 28 50 2e 79 20 2b |;. b |= (P.y +|
|000012b0| 20 64 20 2a 20 44 2e 79 | 29 3b 0d 20 20 20 20 69 | d * D.y|);. i|
|000012c0| 66 20 28 28 61 20 2a 20 | 61 20 2b 20 62 20 2a 20 |f ((a * |a + b * |
|000012d0| 62 29 20 3c 3d 20 28 43 | 6f 6e 65 2d 3e 63 79 6c |b) <= (C|one->cyl|
|000012e0| 5f 66 6c 61 67 20 3f 20 | 31 2e 30 20 3a 20 43 6f |_flag ? |1.0 : Co|
|000012f0| 6e 65 2d 3e 64 69 73 74 | 2a 43 6f 6e 65 2d 3e 64 |ne->dist|*Cone->d|
|00001300| 69 73 74 29 0d 20 20 20 | 20 20 20 26 26 20 64 20 |ist). | && d |
|00001310| 3e 20 43 6f 6e 65 5f 54 | 6f 6c 65 72 61 6e 63 65 |> Cone_T|olerance|
|00001320| 20 26 26 20 64 20 3c 20 | 4d 61 78 5f 44 69 73 74 | && d < |Max_Dist|
|00001330| 61 6e 63 65 29 0d 20 20 | 20 20 20 20 44 65 70 74 |ance). | Dept|
|00001340| 68 73 5b 69 2b 2b 5d 20 | 3d 20 64 2f 6c 65 6e 3b |hs[i++] |= d/len;|
|00001350| 0d 20 20 20 20 7d 0d 0d | 20 20 52 61 79 5f 43 6f |. }..| Ray_Co|
|00001360| 6e 65 5f 54 65 73 74 73 | 5f 53 75 63 63 65 65 64 |ne_Tests|_Succeed|
|00001370| 65 64 20 2b 3d 69 3b 0d | 0d 20 20 72 65 74 75 72 |ed +=i;.|. retur|
|00001380| 6e 28 69 29 3b 0d 20 20 | 7d 0d 0d 69 6e 74 20 49 |n(i);. |}..int I|
|00001390| 6e 73 69 64 65 5f 43 6f | 6e 65 20 28 49 50 6f 69 |nside_Co|ne (IPoi|
|000013a0| 6e 74 2c 20 4f 62 6a 65 | 63 74 29 0d 56 45 43 54 |nt, Obje|ct).VECT|
|000013b0| 4f 52 20 2a 49 50 6f 69 | 6e 74 3b 0d 4f 42 4a 45 |OR *IPoi|nt;.OBJE|
|000013c0| 43 54 20 2a 4f 62 6a 65 | 63 74 3b 0d 20 20 7b 0d |CT *Obje|ct;. {.|
|000013d0| 20 20 56 45 43 54 4f 52 | 20 4e 65 77 5f 50 6f 69 | VECTOR| New_Poi|
|000013e0| 6e 74 3b 0d 20 20 43 4f | 4e 45 20 2a 43 6f 6e 65 |nt;. CO|NE *Cone|
|000013f0| 20 3d 20 28 43 4f 4e 45 | 20 2a 29 20 4f 62 6a 65 | = (CONE| *) Obje|
|00001400| 63 74 3b 0d 20 20 44 42 | 4c 20 77 32 2c 20 7a 32 |ct;. DB|L w2, z2|
|00001410| 2c 20 6f 66 66 73 65 74 | 20 3d 20 28 43 6f 6e 65 |, offset| = (Cone|
|00001420| 2d 3e 49 6e 76 65 72 74 | 65 64 20 3f 20 2d 45 50 |->Invert|ed ? -EP|
|00001430| 53 49 4c 4f 4e 20 3a 20 | 45 50 53 49 4c 4f 4e 29 |SILON : |EPSILON)|
|00001440| 3b 0d 0d 20 20 2f 2a 20 | 54 72 61 6e 73 66 6f 72 |;.. /* |Transfor|
|00001450| 6d 20 74 68 65 20 70 6f | 69 6e 74 20 69 6e 74 6f |m the po|int into|
|00001460| 20 74 68 65 20 63 6f 6e | 65 73 20 73 70 61 63 65 | the con|es space|
|00001470| 20 2a 2f 0d 20 20 4d 49 | 6e 76 54 72 61 6e 73 50 | */. MI|nvTransP|
|00001480| 6f 69 6e 74 28 26 4e 65 | 77 5f 50 6f 69 6e 74 2c |oint(&Ne|w_Point,|
|00001490| 20 49 50 6f 69 6e 74 2c | 20 43 6f 6e 65 2d 3e 54 | IPoint,| Cone->T|
|000014a0| 72 61 6e 73 29 3b 0d 0d | 20 20 2f 2a 20 54 65 73 |rans);..| /* Tes|
|000014b0| 74 20 74 6f 20 73 65 65 | 20 69 66 20 77 65 20 61 |t to see| if we a|
|000014c0| 72 65 20 69 6e 73 69 64 | 65 20 74 68 65 20 63 6f |re insid|e the co|
|000014d0| 6e 65 20 2a 2f 0d 20 20 | 77 32 20 3d 20 4e 65 77 |ne */. |w2 = New|
|000014e0| 5f 50 6f 69 6e 74 2e 78 | 20 2a 20 4e 65 77 5f 50 |_Point.x| * New_P|
|000014f0| 6f 69 6e 74 2e 78 20 2b | 20 4e 65 77 5f 50 6f 69 |oint.x +| New_Poi|
|00001500| 6e 74 2e 79 20 2a 20 4e | 65 77 5f 50 6f 69 6e 74 |nt.y * N|ew_Point|
|00001510| 2e 79 3b 0d 20 20 69 66 | 20 28 43 6f 6e 65 2d 3e |.y;. if| (Cone->|
|00001520| 63 79 6c 5f 66 6c 61 67 | 29 20 0d 20 20 20 20 7b |cyl_flag|) . {|
|00001530| 0d 20 20 20 20 2f 2a 20 | 43 68 65 63 6b 20 74 6f |. /* |Check to|
|00001540| 20 73 65 65 20 69 66 20 | 77 65 20 61 72 65 20 69 | see if |we are i|
|00001550| 6e 73 69 64 65 20 61 20 | 63 79 6c 69 6e 64 65 72 |nside a |cylinder|
|00001560| 20 2a 2f 0d 20 20 20 20 | 69 66 20 28 77 32 20 3e | */. |if (w2 >|
|00001570| 20 31 2e 30 20 2b 20 6f | 66 66 73 65 74 20 7c 7c | 1.0 + o|ffset |||
|00001580| 0d 20 20 20 20 20 20 4e | 65 77 5f 50 6f 69 6e 74 |. N|ew_Point|
|00001590| 2e 7a 20 3c 20 30 2e 30 | 20 2d 20 6f 66 66 73 65 |.z < 0.0| - offse|
|000015a0| 74 20 7c 7c 0d 20 20 20 | 20 20 20 4e 65 77 5f 50 |t ||. | New_P|
|000015b0| 6f 69 6e 74 2e 7a 20 3e | 20 31 2e 30 20 2b 20 6f |oint.z >| 1.0 + o|
|000015c0| 66 66 73 65 74 29 0d 20 | 20 20 20 20 20 72 65 74 |ffset). | ret|
|000015d0| 75 72 6e 20 43 6f 6e 65 | 2d 3e 49 6e 76 65 72 74 |urn Cone|->Invert|
|000015e0| 65 64 3b 0d 20 20 20 20 | 65 6c 73 65 0d 20 20 20 |ed;. |else. |
|000015f0| 20 20 20 72 65 74 75 72 | 6e 20 31 20 2d 20 43 6f | retur|n 1 - Co|
|00001600| 6e 65 2d 3e 49 6e 76 65 | 72 74 65 64 3b 0d 20 20 |ne->Inve|rted;. |
|00001610| 20 20 7d 0d 20 20 65 6c | 73 65 20 0d 20 20 20 20 | }. el|se . |
|00001620| 7b 0d 20 20 20 20 2f 2a | 20 43 68 65 63 6b 20 74 |{. /*| Check t|
|00001630| 6f 20 73 65 65 20 69 66 | 20 77 65 20 61 72 65 20 |o see if| we are |
|00001640| 69 6e 73 69 64 65 20 61 | 20 63 6f 6e 65 20 2a 2f |inside a| cone */|
|00001650| 0d 20 20 20 20 7a 32 20 | 3d 20 4e 65 77 5f 50 6f |. z2 |= New_Po|
|00001660| 69 6e 74 2e 7a 20 2a 20 | 4e 65 77 5f 50 6f 69 6e |int.z * |New_Poin|
|00001670| 74 2e 7a 3b 0d 20 20 20 | 20 69 66 20 28 77 32 20 |t.z;. | if (w2 |
|00001680| 3e 20 7a 32 20 2b 20 6f | 66 66 73 65 74 20 7c 7c |> z2 + o|ffset |||
|00001690| 0d 20 20 20 20 20 20 4e | 65 77 5f 50 6f 69 6e 74 |. N|ew_Point|
|000016a0| 2e 7a 20 3c 20 43 6f 6e | 65 2d 3e 64 69 73 74 20 |.z < Con|e->dist |
|000016b0| 2d 20 6f 66 66 73 65 74 | 20 7c 7c 0d 20 20 20 20 |- offset| ||. |
|000016c0| 20 20 4e 65 77 5f 50 6f | 69 6e 74 2e 7a 20 3e 20 | New_Po|int.z > |
|000016d0| 31 2e 30 2b 6f 66 66 73 | 65 74 29 0d 20 20 20 20 |1.0+offs|et). |
|000016e0| 20 20 72 65 74 75 72 6e | 20 43 6f 6e 65 2d 3e 49 | return| Cone->I|
|000016f0| 6e 76 65 72 74 65 64 3b | 0d 20 20 20 20 65 6c 73 |nverted;|. els|
|00001700| 65 0d 20 20 20 20 20 20 | 72 65 74 75 72 6e 20 31 |e. |return 1|
|00001710| 20 2d 20 43 6f 6e 65 2d | 3e 49 6e 76 65 72 74 65 | - Cone-|>Inverte|
|00001720| 64 3b 0d 20 20 20 20 7d | 0d 20 20 7d 0d 0d 76 6f |d;. }|. }..vo|
|00001730| 69 64 20 43 6f 6e 65 5f | 4e 6f 72 6d 61 6c 20 28 |id Cone_|Normal (|
|00001740| 52 65 73 75 6c 74 2c 20 | 4f 62 6a 65 63 74 2c 20 |Result, |Object, |
|00001750| 49 50 6f 69 6e 74 29 0d | 4f 42 4a 45 43 54 20 2a |IPoint).|OBJECT *|
|00001760| 4f 62 6a 65 63 74 3b 0d | 56 45 43 54 4f 52 20 2a |Object;.|VECTOR *|
|00001770| 52 65 73 75 6c 74 2c 20 | 2a 49 50 6f 69 6e 74 3b |Result, |*IPoint;|
|00001780| 0d 20 20 7b 0d 20 20 43 | 4f 4e 45 20 2a 43 6f 6e |. {. C|ONE *Con|
|00001790| 65 20 3d 20 28 43 4f 4e | 45 20 2a 29 20 4f 62 6a |e = (CON|E *) Obj|
|000017a0| 65 63 74 3b 0d 0d 20 20 | 2f 2a 20 54 72 61 6e 73 |ect;.. |/* Trans|
|000017b0| 66 6f 72 6d 20 74 68 65 | 20 70 6f 69 6e 74 20 69 |form the| point i|
|000017c0| 6e 74 6f 20 74 68 65 20 | 63 6f 6e 65 73 20 73 70 |nto the |cones sp|
|000017d0| 61 63 65 20 2a 2f 0d 20 | 20 4d 49 6e 76 54 72 61 |ace */. | MInvTra|
|000017e0| 6e 73 50 6f 69 6e 74 28 | 52 65 73 75 6c 74 2c 20 |nsPoint(|Result, |
|000017f0| 49 50 6f 69 6e 74 2c 20 | 43 6f 6e 65 2d 3e 54 72 |IPoint, |Cone->Tr|
|00001800| 61 6e 73 29 3b 0d 0d 20 | 20 2f 2a 20 43 61 6c 63 |ans);.. | /* Calc|
|00001810| 75 6c 61 74 69 6e 67 20 | 74 68 65 20 6e 6f 72 6d |ulating |the norm|
|00001820| 61 6c 20 69 73 20 72 65 | 61 6c 20 73 69 6d 70 6c |al is re|al simpl|
|00001830| 65 20 69 6e 20 63 61 6e | 6f 6e 69 63 61 6c 20 63 |e in can|onical c|
|00001840| 6f 6e 65 20 73 70 61 63 | 65 20 2a 2f 0d 20 20 69 |one spac|e */. i|
|00001850| 66 20 28 52 65 73 75 6c | 74 2d 3e 7a 20 3e 20 28 |f (Resul|t->z > (|
|00001860| 31 2d 45 50 53 49 4c 4f | 4e 29 29 0d 20 20 20 20 |1-EPSILO|N)). |
|00001870| 4d 61 6b 65 5f 56 65 63 | 74 6f 72 28 52 65 73 75 |Make_Vec|tor(Resu|
|00001880| 6c 74 2c 30 2e 30 2c 30 | 2e 30 2c 31 2e 30 29 0d |lt,0.0,0|.0,1.0).|
|00001890| 65 6c 73 65 0d 20 20 69 | 66 20 28 52 65 73 75 6c |else. i|f (Resul|
|000018a0| 74 2d 3e 7a 20 3c 20 28 | 43 6f 6e 65 2d 3e 64 69 |t->z < (|Cone->di|
|000018b0| 73 74 2b 45 50 53 49 4c | 4f 4e 29 29 0d 20 20 20 |st+EPSIL|ON)). |
|000018c0| 20 4d 61 6b 65 5f 56 65 | 63 74 6f 72 28 52 65 73 | Make_Ve|ctor(Res|
|000018d0| 75 6c 74 2c 30 2e 30 2c | 30 2e 30 2c 2d 31 2e 30 |ult,0.0,|0.0,-1.0|
|000018e0| 29 0d 65 6c 73 65 0d 20 | 20 69 66 20 28 43 6f 6e |).else. | if (Con|
|000018f0| 65 2d 3e 63 79 6c 5f 66 | 6c 61 67 29 0d 20 20 20 |e->cyl_f|lag). |
|00001900| 20 52 65 73 75 6c 74 2d | 3e 7a 20 3d 20 30 2e 30 | Result-|>z = 0.0|
|00001910| 3b 0d 20 20 65 6c 73 65 | 0d 20 20 20 20 52 65 73 |;. else|. Res|
|00001920| 75 6c 74 2d 3e 7a 20 3d | 20 2d 52 65 73 75 6c 74 |ult->z =| -Result|
|00001930| 2d 3e 7a 3b 0d 0d 2f 2a | 20 54 72 61 6e 73 66 6f |->z;../*| Transfo|
|00001940| 72 6d 20 74 68 65 20 70 | 6f 69 6e 74 20 6f 75 74 |rm the p|oint out|
|00001950| 20 6f 66 20 74 68 65 20 | 63 6f 6e 65 73 20 73 70 | of the |cones sp|
|00001960| 61 63 65 20 2a 2f 0d 4d | 54 72 61 6e 73 4e 6f 72 |ace */.M|TransNor|
|00001970| 6d 61 6c 28 52 65 73 75 | 6c 74 2c 20 52 65 73 75 |mal(Resu|lt, Resu|
|00001980| 6c 74 2c 20 43 6f 6e 65 | 2d 3e 54 72 61 6e 73 29 |lt, Cone|->Trans)|
|00001990| 3b 0d 56 4e 6f 72 6d 61 | 6c 69 7a 65 28 2a 52 65 |;.VNorma|lize(*Re|
|000019a0| 73 75 6c 74 2c 20 2a 52 | 65 73 75 6c 74 29 3b 0d |sult, *R|esult);.|
|000019b0| 7d 0d 0d 76 6f 69 64 20 | 2a 43 6f 70 79 5f 43 6f |}..void |*Copy_Co|
|000019c0| 6e 65 20 28 4f 62 6a 65 | 63 74 29 0d 4f 42 4a 45 |ne (Obje|ct).OBJE|
|000019d0| 43 54 20 2a 4f 62 6a 65 | 63 74 3b 0d 7b 0d 43 4f |CT *Obje|ct;.{.CO|
|000019e0| 4e 45 20 2a 4e 65 77 3b | 0d 0d 4e 65 77 20 20 3d |NE *New;|..New =|
|000019f0| 20 43 72 65 61 74 65 5f | 43 6f 6e 65 28 29 3b 0d | Create_|Cone();.|
|00001a00| 2a 4e 65 77 20 3d 20 2a | 28 28 43 4f 4e 45 20 2a |*New = *|((CONE *|
|00001a10| 29 20 4f 62 6a 65 63 74 | 29 3b 0d 0d 4e 65 77 2d |) Object|);..New-|
|00001a20| 3e 54 72 61 6e 73 20 3d | 20 43 6f 70 79 5f 54 72 |>Trans =| Copy_Tr|
|00001a30| 61 6e 73 66 6f 72 6d 28 | 28 28 43 4f 4e 45 20 2a |ansform(|((CONE *|
|00001a40| 29 4f 62 6a 65 63 74 29 | 2d 3e 54 72 61 6e 73 29 |)Object)|->Trans)|
|00001a50| 3b 0d 0d 72 65 74 75 72 | 6e 20 28 4e 65 77 29 3b |;..retur|n (New);|
|00001a60| 0d 7d 0d 0d 76 6f 69 64 | 20 54 72 61 6e 73 6c 61 |.}..void| Transla|
|00001a70| 74 65 5f 43 6f 6e 65 20 | 28 4f 62 6a 65 63 74 2c |te_Cone |(Object,|
|00001a80| 20 56 65 63 74 6f 72 29 | 0d 4f 42 4a 45 43 54 20 | Vector)|.OBJECT |
|00001a90| 2a 4f 62 6a 65 63 74 3b | 0d 56 45 43 54 4f 52 20 |*Object;|.VECTOR |
|00001aa0| 2a 56 65 63 74 6f 72 3b | 0d 7b 0d 54 52 41 4e 53 |*Vector;|.{.TRANS|
|00001ab0| 46 4f 52 4d 20 54 72 61 | 6e 73 3b 0d 0d 43 6f 6d |FORM Tra|ns;..Com|
|00001ac0| 70 75 74 65 5f 54 72 61 | 6e 73 6c 61 74 69 6f 6e |pute_Tra|nslation|
|00001ad0| 5f 54 72 61 6e 73 66 6f | 72 6d 28 26 54 72 61 6e |_Transfo|rm(&Tran|
|00001ae0| 73 2c 20 56 65 63 74 6f | 72 29 3b 0d 54 72 61 6e |s, Vecto|r);.Tran|
|00001af0| 73 66 6f 72 6d 5f 43 6f | 6e 65 28 4f 62 6a 65 63 |sform_Co|ne(Objec|
|00001b00| 74 2c 20 26 54 72 61 6e | 73 29 3b 0d 7d 0d 0d 76 |t, &Tran|s);.}..v|
|00001b10| 6f 69 64 20 52 6f 74 61 | 74 65 5f 43 6f 6e 65 20 |oid Rota|te_Cone |
|00001b20| 28 4f 62 6a 65 63 74 2c | 20 56 65 63 74 6f 72 29 |(Object,| Vector)|
|00001b30| 0d 4f 42 4a 45 43 54 20 | 2a 4f 62 6a 65 63 74 3b |.OBJECT |*Object;|
|00001b40| 0d 56 45 43 54 4f 52 20 | 2a 56 65 63 74 6f 72 3b |.VECTOR |*Vector;|
|00001b50| 0d 7b 0d 54 52 41 4e 53 | 46 4f 52 4d 20 54 72 61 |.{.TRANS|FORM Tra|
|00001b60| 6e 73 3b 0d 43 6f 6d 70 | 75 74 65 5f 52 6f 74 61 |ns;.Comp|ute_Rota|
|00001b70| 74 69 6f 6e 5f 54 72 61 | 6e 73 66 6f 72 6d 28 26 |tion_Tra|nsform(&|
|00001b80| 54 72 61 6e 73 2c 20 56 | 65 63 74 6f 72 29 3b 0d |Trans, V|ector);.|
|00001b90| 54 72 61 6e 73 66 6f 72 | 6d 5f 43 6f 6e 65 28 4f |Transfor|m_Cone(O|
|00001ba0| 62 6a 65 63 74 2c 20 26 | 54 72 61 6e 73 29 3b 0d |bject, &|Trans);.|
|00001bb0| 7d 0d 0d 76 6f 69 64 20 | 53 63 61 6c 65 5f 43 6f |}..void |Scale_Co|
|00001bc0| 6e 65 20 28 4f 62 6a 65 | 63 74 2c 20 56 65 63 74 |ne (Obje|ct, Vect|
|00001bd0| 6f 72 29 0d 4f 42 4a 45 | 43 54 20 2a 4f 62 6a 65 |or).OBJE|CT *Obje|
|00001be0| 63 74 3b 0d 56 45 43 54 | 4f 52 20 2a 56 65 63 74 |ct;.VECT|OR *Vect|
|00001bf0| 6f 72 3b 0d 7b 0d 54 52 | 41 4e 53 46 4f 52 4d 20 |or;.{.TR|ANSFORM |
|00001c00| 54 72 61 6e 73 3b 0d 0d | 43 6f 6d 70 75 74 65 5f |Trans;..|Compute_|
|00001c10| 53 63 61 6c 69 6e 67 5f | 54 72 61 6e 73 66 6f 72 |Scaling_|Transfor|
|00001c20| 6d 28 26 54 72 61 6e 73 | 2c 20 56 65 63 74 6f 72 |m(&Trans|, Vector|
|00001c30| 29 3b 0d 54 72 61 6e 73 | 66 6f 72 6d 5f 43 6f 6e |);.Trans|form_Con|
|00001c40| 65 28 4f 62 6a 65 63 74 | 2c 20 26 54 72 61 6e 73 |e(Object|, &Trans|
|00001c50| 29 3b 0d 7d 0d 0d 76 6f | 69 64 20 49 6e 76 65 72 |);.}..vo|id Inver|
|00001c60| 74 5f 43 6f 6e 65 20 28 | 4f 62 6a 65 63 74 29 0d |t_Cone (|Object).|
|00001c70| 4f 42 4a 45 43 54 20 2a | 4f 62 6a 65 63 74 3b 0d |OBJECT *|Object;.|
|00001c80| 7b 0d 28 28 43 4f 4e 45 | 20 2a 29 4f 62 6a 65 63 |{.((CONE| *)Objec|
|00001c90| 74 29 2d 3e 49 6e 76 65 | 72 74 65 64 20 3d 20 31 |t)->Inve|rted = 1|
|00001ca0| 20 2d 20 28 28 43 4f 4e | 45 20 2a 29 4f 62 6a 65 | - ((CON|E *)Obje|
|00001cb0| 63 74 29 2d 3e 49 6e 76 | 65 72 74 65 64 3b 0d 7d |ct)->Inv|erted;.}|
|00001cc0| 0d 0d 76 6f 69 64 20 54 | 72 61 6e 73 66 6f 72 6d |..void T|ransform|
|00001cd0| 5f 43 6f 6e 65 20 28 4f | 62 6a 65 63 74 2c 20 54 |_Cone (O|bject, T|
|00001ce0| 72 61 6e 73 29 0d 4f 42 | 4a 45 43 54 20 2a 4f 62 |rans).OB|JECT *Ob|
|00001cf0| 6a 65 63 74 3b 0d 54 52 | 41 4e 53 46 4f 52 4d 20 |ject;.TR|ANSFORM |
|00001d00| 2a 54 72 61 6e 73 3b 0d | 7b 0d 43 4f 4e 45 20 2a |*Trans;.|{.CONE *|
|00001d10| 43 6f 6e 65 20 3d 20 28 | 43 4f 4e 45 20 2a 29 4f |Cone = (|CONE *)O|
|00001d20| 62 6a 65 63 74 3b 0d 43 | 6f 6d 70 6f 73 65 5f 54 |bject;.C|ompose_T|
|00001d30| 72 61 6e 73 66 6f 72 6d | 73 28 43 6f 6e 65 2d 3e |ransform|s(Cone->|
|00001d40| 54 72 61 6e 73 2c 20 54 | 72 61 6e 73 29 3b 0d 0d |Trans, T|rans);..|
|00001d50| 2f 2a 20 52 65 63 61 6c | 63 75 6c 61 74 65 20 74 |/* Recal|culate t|
|00001d60| 68 65 20 62 6f 75 6e 64 | 73 20 2a 2f 0d 4d 61 6b |he bound|s */.Mak|
|00001d70| 65 5f 56 65 63 74 6f 72 | 28 26 43 6f 6e 65 2d 3e |e_Vector|(&Cone->|
|00001d80| 42 6f 75 6e 64 73 2e 4c | 6f 77 65 72 5f 4c 65 66 |Bounds.L|ower_Lef|
|00001d90| 74 2c 20 2d 31 2e 30 2c | 20 2d 31 2e 30 2c 20 30 |t, -1.0,| -1.0, 0|
|00001da0| 2e 30 29 3b 0d 4d 61 6b | 65 5f 56 65 63 74 6f 72 |.0);.Mak|e_Vector|
|00001db0| 28 26 43 6f 6e 65 2d 3e | 42 6f 75 6e 64 73 2e 4c |(&Cone->|Bounds.L|
|00001dc0| 65 6e 67 74 68 73 2c 20 | 32 2e 30 2c 20 32 2e 30 |engths, |2.0, 2.0|
|00001dd0| 2c 20 31 2e 30 29 3b 0d | 72 65 63 6f 6d 70 75 74 |, 1.0);.|recomput|
|00001de0| 65 5f 62 62 6f 78 28 26 | 43 6f 6e 65 2d 3e 42 6f |e_bbox(&|Cone->Bo|
|00001df0| 75 6e 64 73 2c 20 43 6f | 6e 65 2d 3e 54 72 61 6e |unds, Co|ne->Tran|
|00001e00| 73 29 3b 0d 7d 0d 0d 43 | 4f 4e 45 20 2a 43 72 65 |s);.}..C|ONE *Cre|
|00001e10| 61 74 65 5f 43 6f 6e 65 | 20 28 29 0d 7b 0d 43 4f |ate_Cone| ().{.CO|
|00001e20| 4e 45 20 2a 4e 65 77 3b | 0d 0d 69 66 20 28 28 4e |NE *New;|..if ((N|
|00001e30| 65 77 20 3d 20 28 43 4f | 4e 45 20 2a 29 20 6d 61 |ew = (CO|NE *) ma|
|00001e40| 6c 6c 6f 63 20 28 73 69 | 7a 65 6f 66 20 28 43 4f |lloc (si|zeof (CO|
|00001e50| 4e 45 29 29 29 20 3d 3d | 20 4e 55 4c 4c 29 0d 4d |NE))) ==| NULL).M|
|00001e60| 41 45 72 72 6f 72 20 28 | 22 63 6f 6e 65 22 29 3b |AError (|"cone");|
|00001e70| 0d 0d 49 4e 49 54 5f 4f | 42 4a 45 43 54 5f 46 49 |..INIT_O|BJECT_FI|
|00001e80| 45 4c 44 53 28 4e 65 77 | 2c 20 43 4f 4e 45 5f 4f |ELDS(New|, CONE_O|
|00001e90| 42 4a 45 43 54 2c 20 26 | 43 6f 6e 65 5f 4d 65 74 |BJECT, &|Cone_Met|
|00001ea0| 68 6f 64 73 29 0d 4d 61 | 6b 65 5f 56 65 63 74 6f |hods).Ma|ke_Vecto|
|00001eb0| 72 20 28 26 28 4e 65 77 | 2d 3e 61 70 65 78 29 2c |r (&(New|->apex),|
|00001ec0| 20 30 2e 30 2c 20 30 2e | 30 2c 20 31 2e 30 29 3b | 0.0, 0.|0, 1.0);|
|00001ed0| 0d 4d 61 6b 65 5f 56 65 | 63 74 6f 72 20 28 26 28 |.Make_Ve|ctor (&(|
|00001ee0| 4e 65 77 2d 3e 62 61 73 | 65 29 2c 20 30 2e 30 2c |New->bas|e), 0.0,|
|00001ef0| 20 30 2e 30 2c 20 30 2e | 30 29 3b 0d 4e 65 77 2d | 0.0, 0.|0);.New-|
|00001f00| 3e 61 70 65 78 5f 72 61 | 64 69 75 73 20 3d 20 31 |>apex_ra|dius = 1|
|00001f10| 2e 30 3b 0d 4e 65 77 2d | 3e 62 61 73 65 5f 72 61 |.0;.New-|>base_ra|
|00001f20| 64 69 75 73 20 3d 20 30 | 2e 30 3b 0d 4e 65 77 2d |dius = 0|.0;.New-|
|00001f30| 3e 64 69 73 74 20 3d 20 | 30 2e 30 3b 0d 4e 65 77 |>dist = |0.0;.New|
|00001f40| 2d 3e 54 72 61 6e 73 20 | 3d 20 43 72 65 61 74 65 |->Trans |= Create|
|00001f50| 5f 54 72 61 6e 73 66 6f | 72 6d 28 29 3b 0d 4e 65 |_Transfo|rm();.Ne|
|00001f60| 77 2d 3e 49 6e 76 65 72 | 74 65 64 20 3d 20 46 41 |w->Inver|ted = FA|
|00001f70| 4c 53 45 3b 0d 4e 65 77 | 2d 3e 63 79 6c 5f 66 6c |LSE;.New|->cyl_fl|
|00001f80| 61 67 20 3d 20 30 3b 20 | 2f 2a 20 54 68 69 73 20 |ag = 0; |/* This |
|00001f90| 69 73 20 61 20 43 6f 6e | 65 20 2a 2f 0d 4e 65 77 |is a Con|e */.New|
|00001fa0| 2d 3e 63 6c 6f 73 65 64 | 20 20 20 3d 20 31 3b 20 |->closed| = 1; |
|00001fb0| 2f 2a 20 48 61 73 20 63 | 61 70 70 65 64 20 65 6e |/* Has c|apped en|
|00001fc0| 64 73 2a 2f 0d 0d 2f 2a | 20 44 65 66 61 75 6c 74 |ds*/../*| Default|
|00001fd0| 20 62 6f 75 6e 64 73 20 | 2a 2f 0d 4d 61 6b 65 5f | bounds |*/.Make_|
|00001fe0| 56 65 63 74 6f 72 28 26 | 4e 65 77 2d 3e 42 6f 75 |Vector(&|New->Bou|
|00001ff0| 6e 64 73 2e 4c 6f 77 65 | 72 5f 4c 65 66 74 2c 20 |nds.Lowe|r_Left, |
|00002000| 2d 31 2e 30 2c 20 2d 31 | 2e 30 2c 20 30 2e 30 29 |-1.0, -1|.0, 0.0)|
|00002010| 3b 0d 4d 61 6b 65 5f 56 | 65 63 74 6f 72 28 26 4e |;.Make_V|ector(&N|
|00002020| 65 77 2d 3e 42 6f 75 6e | 64 73 2e 4c 65 6e 67 74 |ew->Boun|ds.Lengt|
|00002030| 68 73 2c 20 32 2e 30 2c | 20 32 2e 30 2c 20 31 2e |hs, 2.0,| 2.0, 1.|
|00002040| 30 29 3b 0d 0d 72 65 74 | 75 72 6e 20 4e 65 77 3b |0);..ret|urn New;|
|00002050| 0d 7d 0d 0d 43 4f 4e 45 | 20 2a 43 72 65 61 74 65 |.}..CONE| *Create|
|00002060| 5f 43 79 6c 69 6e 64 65 | 72 20 28 29 0d 7b 0d 43 |_Cylinde|r ().{.C|
|00002070| 4f 4e 45 20 2a 4e 65 77 | 3b 0d 0d 69 66 20 28 28 |ONE *New|;..if ((|
|00002080| 4e 65 77 20 3d 20 28 43 | 4f 4e 45 20 2a 29 20 6d |New = (C|ONE *) m|
|00002090| 61 6c 6c 6f 63 20 28 73 | 69 7a 65 6f 66 20 28 43 |alloc (s|izeof (C|
|000020a0| 4f 4e 45 29 29 29 20 3d | 3d 20 4e 55 4c 4c 29 0d |ONE))) =|= NULL).|
|000020b0| 4d 41 45 72 72 6f 72 20 | 28 22 63 6f 6e 65 22 29 |MAError |("cone")|
|000020c0| 3b 0d 0d 49 4e 49 54 5f | 4f 42 4a 45 43 54 5f 46 |;..INIT_|OBJECT_F|
|000020d0| 49 45 4c 44 53 28 4e 65 | 77 2c 20 43 4f 4e 45 5f |IELDS(Ne|w, CONE_|
|000020e0| 4f 42 4a 45 43 54 2c 20 | 26 43 6f 6e 65 5f 4d 65 |OBJECT, |&Cone_Me|
|000020f0| 74 68 6f 64 73 29 0d 4d | 61 6b 65 5f 56 65 63 74 |thods).M|ake_Vect|
|00002100| 6f 72 20 28 26 28 4e 65 | 77 2d 3e 61 70 65 78 29 |or (&(Ne|w->apex)|
|00002110| 2c 20 30 2e 30 2c 20 30 | 2e 30 2c 20 31 2e 30 29 |, 0.0, 0|.0, 1.0)|
|00002120| 3b 0d 4d 61 6b 65 5f 56 | 65 63 74 6f 72 20 28 26 |;.Make_V|ector (&|
|00002130| 28 4e 65 77 2d 3e 62 61 | 73 65 29 2c 20 30 2e 30 |(New->ba|se), 0.0|
|00002140| 2c 20 30 2e 30 2c 20 30 | 2e 30 29 3b 0d 4e 65 77 |, 0.0, 0|.0);.New|
|00002150| 2d 3e 61 70 65 78 5f 72 | 61 64 69 75 73 20 3d 20 |->apex_r|adius = |
|00002160| 31 2e 30 3b 0d 4e 65 77 | 2d 3e 62 61 73 65 5f 72 |1.0;.New|->base_r|
|00002170| 61 64 69 75 73 20 3d 20 | 31 2e 30 3b 0d 4e 65 77 |adius = |1.0;.New|
|00002180| 2d 3e 64 69 73 74 20 3d | 20 30 2e 30 3b 0d 4e 65 |->dist =| 0.0;.Ne|
|00002190| 77 2d 3e 54 72 61 6e 73 | 20 3d 20 43 72 65 61 74 |w->Trans| = Creat|
|000021a0| 65 5f 54 72 61 6e 73 66 | 6f 72 6d 28 29 3b 0d 4e |e_Transf|orm();.N|
|000021b0| 65 77 2d 3e 49 6e 76 65 | 72 74 65 64 20 3d 20 46 |ew->Inve|rted = F|
|000021c0| 41 4c 53 45 3b 0d 4e 65 | 77 2d 3e 63 79 6c 5f 66 |ALSE;.Ne|w->cyl_f|
|000021d0| 6c 61 67 20 3d 20 31 3b | 20 2f 2a 20 54 68 69 73 |lag = 1;| /* This|
|000021e0| 20 69 73 20 61 20 43 79 | 6c 69 6e 64 65 72 20 2a | is a Cy|linder *|
|000021f0| 2f 0d 4e 65 77 2d 3e 63 | 6c 6f 73 65 64 20 20 20 |/.New->c|losed |
|00002200| 3d 20 31 3b 20 2f 2a 20 | 48 61 73 20 63 61 70 70 |= 1; /* |Has capp|
|00002210| 65 64 20 65 6e 64 73 2a | 2f 0d 0d 2f 2a 20 44 65 |ed ends*|/../* De|
|00002220| 66 61 75 6c 74 20 62 6f | 75 6e 64 73 20 2a 2f 0d |fault bo|unds */.|
|00002230| 4d 61 6b 65 5f 56 65 63 | 74 6f 72 28 26 4e 65 77 |Make_Vec|tor(&New|
|00002240| 2d 3e 42 6f 75 6e 64 73 | 2e 4c 6f 77 65 72 5f 4c |->Bounds|.Lower_L|
|00002250| 65 66 74 2c 20 2d 31 2e | 30 2c 20 2d 31 2e 30 2c |eft, -1.|0, -1.0,|
|00002260| 20 30 2e 30 29 3b 0d 4d | 61 6b 65 5f 56 65 63 74 | 0.0);.M|ake_Vect|
|00002270| 6f 72 28 26 4e 65 77 2d | 3e 42 6f 75 6e 64 73 2e |or(&New-|>Bounds.|
|00002280| 4c 65 6e 67 74 68 73 2c | 20 32 2e 30 2c 20 32 2e |Lengths,| 2.0, 2.|
|00002290| 30 2c 20 31 2e 30 29 3b | 0d 0d 72 65 74 75 72 6e |0, 1.0);|..return|
|000022a0| 20 4e 65 77 3b 0d 7d 0d | 0d 76 6f 69 64 20 43 6f | New;.}.|.void Co|
|000022b0| 6d 70 75 74 65 5f 43 6f | 6e 65 5f 44 61 74 61 28 |mpute_Co|ne_Data(|
|000022c0| 4f 62 6a 65 63 74 29 0d | 4f 42 4a 45 43 54 20 2a |Object).|OBJECT *|
|000022d0| 4f 62 6a 65 63 74 3b 0d | 7b 0d 44 42 4c 20 74 6c |Object;.|{.DBL tl|
|000022e0| 65 6e 2c 20 6c 65 6e 2c | 20 74 6d 70 66 3b 0d 56 |en, len,| tmpf;.V|
|000022f0| 45 43 54 4f 52 20 74 6d | 70 76 2c 20 61 78 69 73 |ECTOR tm|pv, axis|
|00002300| 2c 20 6f 72 69 67 69 6e | 3b 0d 43 4f 4e 45 20 2a |, origin|;.CONE *|
|00002310| 43 6f 6e 65 20 3d 20 28 | 43 4f 4e 45 20 2a 29 4f |Cone = (|CONE *)O|
|00002320| 62 6a 65 63 74 3b 0d 0d | 2f 2a 20 50 72 6f 63 65 |bject;..|/* Proce|
|00002330| 73 73 20 74 68 65 20 70 | 72 69 6d 69 74 69 76 65 |ss the p|rimitive|
|00002340| 20 73 70 65 63 69 66 69 | 63 20 69 6e 66 6f 72 6d | specifi|c inform|
|00002350| 61 74 69 6f 6e 20 2a 2f | 0d 69 66 28 43 6f 6e 65 |ation */|.if(Cone|
|00002360| 2d 3e 61 70 65 78 5f 72 | 61 64 69 75 73 20 3c 20 |->apex_r|adius < |
|00002370| 43 6f 6e 65 2d 3e 62 61 | 73 65 5f 72 61 64 69 75 |Cone->ba|se_radiu|
|00002380| 73 29 20 0d 20 20 7b 0d | 20 20 2f 2a 20 57 61 6e |s) . {.| /* Wan|
|00002390| 74 20 74 68 65 20 62 69 | 67 67 65 72 20 65 6e 64 |t the bi|gger end|
|000023a0| 20 61 74 20 74 68 65 20 | 74 6f 70 20 2a 2f 0d 20 | at the |top */. |
|000023b0| 20 74 6d 70 76 20 3d 20 | 43 6f 6e 65 2d 3e 62 61 | tmpv = |Cone->ba|
|000023c0| 73 65 3b 0d 20 20 43 6f | 6e 65 2d 3e 62 61 73 65 |se;. Co|ne->base|
|000023d0| 20 3d 20 43 6f 6e 65 2d | 3e 61 70 65 78 3b 0d 20 | = Cone-|>apex;. |
|000023e0| 20 43 6f 6e 65 2d 3e 61 | 70 65 78 20 3d 20 74 6d | Cone->a|pex = tm|
|000023f0| 70 76 3b 0d 20 20 74 6d | 70 66 20 3d 20 43 6f 6e |pv;. tm|pf = Con|
|00002400| 65 2d 3e 62 61 73 65 5f | 72 61 64 69 75 73 3b 0d |e->base_|radius;.|
|00002410| 20 20 43 6f 6e 65 2d 3e | 62 61 73 65 5f 72 61 64 | Cone->|base_rad|
|00002420| 69 75 73 20 3d 20 43 6f | 6e 65 2d 3e 61 70 65 78 |ius = Co|ne->apex|
|00002430| 5f 72 61 64 69 75 73 3b | 0d 20 20 43 6f 6e 65 2d |_radius;|. Cone-|
|00002440| 3e 61 70 65 78 5f 72 61 | 64 69 75 73 20 3d 20 74 |>apex_ra|dius = t|
|00002450| 6d 70 66 3b 0d 20 20 7d | 0d 65 6c 73 65 20 69 66 |mpf;. }|.else if|
|00002460| 20 28 66 61 62 73 28 43 | 6f 6e 65 2d 3e 61 70 65 | (fabs(C|one->ape|
|00002470| 78 5f 72 61 64 69 75 73 | 20 2d 20 43 6f 6e 65 2d |x_radius| - Cone-|
|00002480| 3e 62 61 73 65 5f 72 61 | 64 69 75 73 29 20 3c 20 |>base_ra|dius) < |
|00002490| 45 50 53 49 4c 4f 4e 29 | 20 0d 20 20 7b 0d 20 20 |EPSILON)| . {. |
|000024a0| 2f 2a 20 57 68 61 74 20 | 77 65 20 61 72 65 20 64 |/* What |we are d|
|000024b0| 65 61 6c 69 6e 67 20 77 | 69 74 68 20 68 65 72 65 |ealing w|ith here|
|000024c0| 20 69 73 20 72 65 61 6c | 6c 79 20 61 20 63 79 6c | is real|ly a cyl|
|000024d0| 69 6e 64 65 72 20 2a 2f | 0d 20 20 43 6f 6e 65 2d |inder */|. Cone-|
|000024e0| 3e 63 79 6c 5f 66 6c 61 | 67 20 3d 20 31 3b 0d 20 |>cyl_fla|g = 1;. |
|000024f0| 20 43 6f 6d 70 75 74 65 | 5f 43 79 6c 69 6e 64 65 | Compute|_Cylinde|
|00002500| 72 5f 44 61 74 61 28 4f | 62 6a 65 63 74 29 3b 0d |r_Data(O|bject);.|
|00002510| 20 20 72 65 74 75 72 6e | 3b 0d 20 20 7d 0d 0d 2f | return|;. }../|
|00002520| 2a 20 46 69 6e 64 20 74 | 68 65 20 61 78 69 73 20 |* Find t|he axis |
|00002530| 61 6e 64 20 61 78 69 73 | 20 6c 65 6e 67 74 68 20 |and axis| length |
|00002540| 2a 2f 0d 56 53 75 62 28 | 61 78 69 73 2c 20 43 6f |*/.VSub(|axis, Co|
|00002550| 6e 65 2d 3e 61 70 65 78 | 2c 20 43 6f 6e 65 2d 3e |ne->apex|, Cone->|
|00002560| 62 61 73 65 29 3b 0d 56 | 4c 65 6e 67 74 68 28 6c |base);.V|Length(l|
|00002570| 65 6e 2c 20 61 78 69 73 | 29 3b 0d 69 66 20 28 6c |en, axis|);.if (l|
|00002580| 65 6e 20 3c 20 45 50 53 | 49 4c 4f 4e 29 0d 45 72 |en < EPS|ILON).Er|
|00002590| 72 6f 72 28 22 44 65 67 | 65 6e 65 72 61 74 65 20 |ror("Deg|enerate |
|000025a0| 63 6f 6e 65 2f 63 79 6c | 69 6e 64 65 72 5c 6e 22 |cone/cyl|inder\n"|
|000025b0| 29 3b 0d 65 6c 73 65 0d | 20 20 56 49 6e 76 65 72 |);.else.| VInver|
|000025c0| 73 65 53 63 61 6c 65 45 | 71 28 61 78 69 73 2c 20 |seScaleE|q(axis, |
|000025d0| 6c 65 6e 29 0d 0d 20 20 | 20 20 2f 2a 20 44 65 74 |len).. | /* Det|
|000025e0| 65 72 6d 69 6e 65 20 61 | 6c 69 67 6e 6d 65 6e 74 |ermine a|lignment|
|000025f0| 20 2a 2f 0d 20 20 20 20 | 74 6d 70 66 20 3d 20 43 | */. |tmpf = C|
|00002600| 6f 6e 65 2d 3e 62 61 73 | 65 5f 72 61 64 69 75 73 |one->bas|e_radius|
|00002610| 20 2a 0d 20 20 20 20 6c | 65 6e 20 2f 20 28 43 6f | *. l|en / (Co|
|00002620| 6e 65 2d 3e 61 70 65 78 | 5f 72 61 64 69 75 73 20 |ne->apex|_radius |
|00002630| 2d 20 43 6f 6e 65 2d 3e | 62 61 73 65 5f 72 61 64 |- Cone->|base_rad|
|00002640| 69 75 73 29 3b 0d 56 53 | 63 61 6c 65 28 6f 72 69 |ius);.VS|cale(ori|
|00002650| 67 69 6e 2c 20 61 78 69 | 73 2c 20 74 6d 70 66 29 |gin, axi|s, tmpf)|
|00002660| 3b 0d 56 53 75 62 28 6f | 72 69 67 69 6e 2c 20 43 |;.VSub(o|rigin, C|
|00002670| 6f 6e 65 2d 3e 62 61 73 | 65 2c 20 6f 72 69 67 69 |one->bas|e, origi|
|00002680| 6e 29 3b 0d 74 6c 65 6e | 20 3d 20 74 6d 70 66 20 |n);.tlen| = tmpf |
|00002690| 2b 20 6c 65 6e 3b 0d 43 | 6f 6e 65 2d 3e 64 69 73 |+ len;.C|one->dis|
|000026a0| 74 20 3d 20 74 6d 70 66 | 20 2f 20 74 6c 65 6e 3b |t = tmpf| / tlen;|
|000026b0| 0d 43 6f 6d 70 75 74 65 | 5f 43 6f 6f 72 64 69 6e |.Compute|_Coordin|
|000026c0| 61 74 65 5f 54 72 61 6e | 73 66 6f 72 6d 28 43 6f |ate_Tran|sform(Co|
|000026d0| 6e 65 2d 3e 54 72 61 6e | 73 2c 20 26 6f 72 69 67 |ne->Tran|s, &orig|
|000026e0| 69 6e 2c 20 26 61 78 69 | 73 2c 0d 43 6f 6e 65 2d |in, &axi|s,.Cone-|
|000026f0| 3e 61 70 65 78 5f 72 61 | 64 69 75 73 2c 20 74 6c |>apex_ra|dius, tl|
|00002700| 65 6e 29 3b 0d 0d 2f 2a | 20 52 65 63 61 6c 63 75 |en);../*| Recalcu|
|00002710| 6c 61 74 65 20 74 68 65 | 20 62 6f 75 6e 64 73 20 |late the| bounds |
|00002720| 2a 2f 0d 4d 61 6b 65 5f | 56 65 63 74 6f 72 28 26 |*/.Make_|Vector(&|
|00002730| 43 6f 6e 65 2d 3e 42 6f | 75 6e 64 73 2e 4c 6f 77 |Cone->Bo|unds.Low|
|00002740| 65 72 5f 4c 65 66 74 2c | 20 2d 31 2e 30 2c 20 2d |er_Left,| -1.0, -|
|00002750| 31 2e 30 2c 20 30 2e 30 | 29 3b 0d 4d 61 6b 65 5f |1.0, 0.0|);.Make_|
|00002760| 56 65 63 74 6f 72 28 26 | 43 6f 6e 65 2d 3e 42 6f |Vector(&|Cone->Bo|
|00002770| 75 6e 64 73 2e 4c 65 6e | 67 74 68 73 2c 20 32 2e |unds.Len|gths, 2.|
|00002780| 30 2c 20 32 2e 30 2c 20 | 31 2e 30 29 3b 0d 72 65 |0, 2.0, |1.0);.re|
|00002790| 63 6f 6d 70 75 74 65 5f | 62 62 6f 78 28 26 43 6f |compute_|bbox(&Co|
|000027a0| 6e 65 2d 3e 42 6f 75 6e | 64 73 2c 20 43 6f 6e 65 |ne->Boun|ds, Cone|
|000027b0| 2d 3e 54 72 61 6e 73 29 | 3b 0d 7d 0d 0d 76 6f 69 |->Trans)|;.}..voi|
|000027c0| 64 20 43 6f 6d 70 75 74 | 65 5f 43 79 6c 69 6e 64 |d Comput|e_Cylind|
|000027d0| 65 72 5f 44 61 74 61 28 | 4f 62 6a 65 63 74 29 0d |er_Data(|Object).|
|000027e0| 4f 42 4a 45 43 54 20 2a | 4f 62 6a 65 63 74 3b 0d |OBJECT *|Object;.|
|000027f0| 7b 0d 43 4f 4e 45 20 2a | 43 6f 6e 65 20 3d 20 28 |{.CONE *|Cone = (|
|00002800| 43 4f 4e 45 20 2a 29 4f | 62 6a 65 63 74 3b 0d 56 |CONE *)O|bject;.V|
|00002810| 45 43 54 4f 52 20 61 78 | 69 73 3b 0d 44 42 4c 20 |ECTOR ax|is;.DBL |
|00002820| 74 6d 70 66 3b 0d 0d 56 | 53 75 62 28 61 78 69 73 |tmpf;..V|Sub(axis|
|00002830| 2c 20 43 6f 6e 65 2d 3e | 61 70 65 78 2c 20 43 6f |, Cone->|apex, Co|
|00002840| 6e 65 2d 3e 62 61 73 65 | 29 3b 0d 56 4c 65 6e 67 |ne->base|);.VLeng|
|00002850| 74 68 28 74 6d 70 66 2c | 20 61 78 69 73 29 3b 0d |th(tmpf,| axis);.|
|00002860| 69 66 20 28 74 6d 70 66 | 20 3c 20 45 50 53 49 4c |if (tmpf| < EPSIL|
|00002870| 4f 4e 29 0d 45 72 72 6f | 72 28 22 44 65 67 65 6e |ON).Erro|r("Degen|
|00002880| 65 72 61 74 65 20 63 79 | 6c 69 6e 64 65 72 2c 20 |erate cy|linder, |
|00002890| 62 61 73 65 20 70 6f 69 | 6e 74 20 3d 20 61 70 65 |base poi|nt = ape|
|000028a0| 78 20 70 6f 69 6e 74 5c | 6e 22 29 3b 0d 65 6c 73 |x point\|n");.els|
|000028b0| 65 0d 20 20 56 49 6e 76 | 65 72 73 65 53 63 61 6c |e. VInv|erseScal|
|000028c0| 65 45 71 28 61 78 69 73 | 2c 20 74 6d 70 66 29 0d |eEq(axis|, tmpf).|
|000028d0| 20 20 20 20 43 6f 6d 70 | 75 74 65 5f 43 6f 6f 72 | Comp|ute_Coor|
|000028e0| 64 69 6e 61 74 65 5f 54 | 72 61 6e 73 66 6f 72 6d |dinate_T|ransform|
|000028f0| 28 43 6f 6e 65 2d 3e 54 | 72 61 6e 73 2c 20 26 43 |(Cone->T|rans, &C|
|00002900| 6f 6e 65 2d 3e 62 61 73 | 65 2c 20 26 61 78 69 73 |one->bas|e, &axis|
|00002910| 2c 0d 20 20 20 20 20 20 | 43 6f 6e 65 2d 3e 61 70 |,. |Cone->ap|
|00002920| 65 78 5f 72 61 64 69 75 | 73 2c 20 74 6d 70 66 29 |ex_radiu|s, tmpf)|
|00002930| 3b 0d 0d 43 6f 6e 65 2d | 3e 64 69 73 74 20 3d 20 |;..Cone-|>dist = |
|00002940| 30 2e 30 3b 0d 2f 2a 20 | 52 65 63 61 6c 63 75 6c |0.0;./* |Recalcul|
|00002950| 61 74 65 20 74 68 65 20 | 62 6f 75 6e 64 73 20 2a |ate the |bounds *|
|00002960| 2f 0d 4d 61 6b 65 5f 56 | 65 63 74 6f 72 28 26 43 |/.Make_V|ector(&C|
|00002970| 6f 6e 65 2d 3e 42 6f 75 | 6e 64 73 2e 4c 6f 77 65 |one->Bou|nds.Lowe|
|00002980| 72 5f 4c 65 66 74 2c 20 | 2d 31 2e 30 2c 20 2d 31 |r_Left, |-1.0, -1|
|00002990| 2e 30 2c 20 30 2e 30 29 | 3b 0d 4d 61 6b 65 5f 56 |.0, 0.0)|;.Make_V|
|000029a0| 65 63 74 6f 72 28 26 43 | 6f 6e 65 2d 3e 42 6f 75 |ector(&C|one->Bou|
|000029b0| 6e 64 73 2e 4c 65 6e 67 | 74 68 73 2c 20 32 2e 30 |nds.Leng|ths, 2.0|
|000029c0| 2c 20 32 2e 30 2c 20 31 | 2e 30 29 3b 0d 72 65 63 |, 2.0, 1|.0);.rec|
|000029d0| 6f 6d 70 75 74 65 5f 62 | 62 6f 78 28 26 43 6f 6e |ompute_b|box(&Con|
|000029e0| 65 2d 3e 42 6f 75 6e 64 | 73 2c 20 43 6f 6e 65 2d |e->Bound|s, Cone-|
|000029f0| 3e 54 72 61 6e 73 29 3b | 0d 7d 0d 0d 0d 76 6f 69 |>Trans);|.}...voi|
|00002a00| 64 20 44 65 73 74 72 6f | 79 5f 43 6f 6e 65 20 28 |d Destro|y_Cone (|
|00002a10| 4f 62 6a 65 63 74 29 0d | 4f 42 4a 45 43 54 20 2a |Object).|OBJECT *|
|00002a20| 4f 62 6a 65 63 74 3b 0d | 7b 0d 44 65 73 74 72 6f |Object;.|{.Destro|
|00002a30| 79 5f 54 72 61 6e 73 66 | 6f 72 6d 28 28 28 43 4f |y_Transf|orm(((CO|
|00002a40| 4e 45 20 2a 29 4f 62 6a | 65 63 74 29 2d 3e 54 72 |NE *)Obj|ect)->Tr|
|00002a50| 61 6e 73 29 3b 0d 66 72 | 65 65 20 28 4f 62 6a 65 |ans);.fr|ee (Obje|
|00002a60| 63 74 29 3b 0d 7d 0d 00 | 00 00 00 00 00 00 00 00 |ct);.}..|........|
|00002a70| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002a80| 00 00 01 00 00 00 01 6e | 00 00 00 6e 00 00 00 3e |.......n|...n...>|
|00002a90| a5 20 7b 66 7d 0d 66 69 | 6e 64 20 22 56 65 72 73 |. {f}.fi|nd "Vers|
|00002aa0| 69 6f 6e 3a 09 32 2e 30 | 22 20 7b 66 7d 0d 65 6e |ion:.2.0|" {f}.en|
|00002ab0| 07 43 4f 4e 45 53 2e 43 | 02 00 00 00 54 45 58 54 |.CONES.C|....TEXT|
|00002ac0| 4d 50 53 20 01 08 ff ff | ff ff 00 00 00 00 16 97 |MPS ....|........|
|00002ad0| 00 00 54 45 58 54 4d 50 | 53 20 01 08 ff ff ff ff |..TEXTMP|S ......|
|00002ae0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002af0| 00 00 a8 7c 6e 18 00 00 | 29 e7 00 00 01 ac 73 65 |...|n...|).....se|
|00002b00| 67 50 4f 56 52 61 79 09 | 09 3d 20 2d 73 20 27 70 |gPOVRay.|.= -s 'p|
|00002b10| 6f 76 52 61 79 27 0d 73 | 65 67 50 72 69 6d 31 09 |ovRay'.s|egPrim1.|
|00002b20| 09 3d 20 2d 73 20 27 70 | 6f 76 50 72 69 6d 31 27 |.= -s 'p|ovPrim1'|
|00002b30| 0d 73 65 67 50 72 69 6d | 32 09 09 3d 20 2d 73 20 |.segPrim|2..= -s |
|00002b40| 27 70 6f 76 50 72 69 6d | 32 27 0d 73 65 67 52 65 |'povPrim|2'.segRe|
|00002b50| 6e 64 65 72 09 09 3d 20 | 2d 73 20 27 70 6f 76 52 |nder..= |-s 'povR|
|00002b60| 65 6e 64 65 72 27 0d 73 | 65 67 54 65 78 09 09 09 |ender'.s|egTex...|
|00002b70| 3d 20 2d 73 20 27 70 6f | 76 54 65 78 27 0d 73 65 |= -s 'po|vTex'.se|
|00002b80| 00 00 00 48 00 09 4d 6f | 6e 61 63 6f 00 00 00 94 |...H..Mo|naco....|
|00002b90| 00 02 56 b8 00 0a 00 02 | 01 b9 00 11 01 d5 00 00 |..V.....|........|
|00002ba0| 00 00 00 00 00 00 00 06 | 00 04 00 c8 00 08 01 dd |........|........|
|00002bb0| 02 3d 00 c8 00 08 01 dd | 02 3d a8 7c 6e 18 00 00 |.=......|.=.|n...|
|00002bc0| 00 00 00 00 00 00 00 00 | 00 00 01 00 00 00 00 1e |........|........|
|00002bd0| 00 c8 00 08 01 dd 02 3d | 00 c8 00 08 01 dd 02 3d |.......=|.......=|
|00002be0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002bf0| 01 00 00 00 01 6e 00 00 | 00 6e 00 00 00 3e 00 8d |.....n..|.n...>..|
|00002c00| 3b f8 18 3e 00 00 00 1c | 00 3e 00 00 4d 50 53 52 |;..>....|.>..MPSR|
|00002c10| 00 01 00 0a 03 ed ff ff | 00 00 00 00 00 00 00 00 |........|........|
|00002c20| 03 f0 ff ff 00 00 00 4c | 00 8f 92 b0 00 00 00 00 |.......L|........|
|00002c30| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002c40| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002c50| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002c60| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002c70| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
+--------+-------------------------+-------------------------+--------+--------+